package main.java;

/**
 * @program: pratice
 * @author: 关键我是大怪
 * @create: 2021-10-28 19:22
 */

/**
 * 给你一个整数 n，请你判断该整数是否是 2 的幂次方。如果是，返回 true ；否则，返回 false 。
 * 如果存在一个整数 x 使得 n == 2x ，则认为 n 是 2 的幂次方。
 * <p>
 * 示例：
 * 输入：n = 1
 * 输出：true
 * 解释：20 = 1
 * <p>
 * 输入：n = 16
 * 输出：true
 * 解释：24 = 16
 */
public class Test63_重新排序得到2的幂 {
    public boolean reorderedPowerOf2(int n) {
        if (n == 0) {
            return false;
        }
        int x = n;
        while (x != 1) {
            if (x % 2 != 0) {
                return false;
            }
            x >>= 1;
        }
        return true;
    }

}
